Back up and instance
SkySQL Snapshot Backups
Overview
Snapshot Backup Examples
SkySQL supports database snapshot backups either on-demand or according to a pre-established schedule. Below are examples of how to schedule a snapshot backup using the SkySQL API.
Important: Database snapshots are deleted immediately upon service deletion.
References
Full (physical) Backups
Overview
Full (physical) Backup Examples
SkySQL supports database physical backups either on-demand or according to a pre-established schedule. Below are examples of how to schedule a physical backup using the SkySQL API.
References
Incremental Backups
Overview
Incremental backups update a previous backup with any changes to the data that have occurred since the initial backup was taken. InnoDB pages contain log sequence numbers, or LSN's. Whenever you modify a row on any InnoDB table in the database, the storage engine increments this number. When performing an incremental backup, Mariabackup checks the most recent LSN for the backup against the LSN's contained in the database. It then updates any of the backup files that have fallen behind.
Incremental Backup Examples
SkySQL supports database incremental backups either on-demand or according to a pre-established schedule. Below are examples of how to schedule an incremental backup using the SkySQL API.
Logical (Mariadb-dump) Backups
Overview
Logical backups consist of the SQL statements necessary to restore the data, such as CREATE DATABASE, CREATE TABLE, and INSERT. This is done using mariadb-dump ([mariadb-dump](https://mariadb.com/kb/en/mariadb-dump/)) and is the most flexible way to perform a backup and restore, and a good choice when the data size is relatively small.
Logical Backup Examples
SkySQL supports database logical backups either on-demand or according to a pre-established schedule. Below are examples of how to schedule a logical backup using the SkySQL API.
References
[mariadb-dump](https://mariadb.com/kb/en/mariadb-dump/)
BinaryLog Backups
Overview
Binlogs record database changes (data modifications, table structure changes) in a sequential, binary format. You can preserve binlogs for setting up replication or to recover to a certain point-in-time.
BinaryLog Backup Examples
Additional Backup Options (with Examples)
- Replication as Backup : In situations where the service cannot be locked or stopped, or is under heavy load, performing backups directly on a primary server may not be the preferred option. Using a replica database instance for backups allows the replica to be shut down or locked, enabling backup operations without impacting the primary server. The approach is commonly implemented in the following manner: - The primary server replicates data to a replica. - Backups are then initiated from the replica, ensuring no disruption to the primary server. Details on how to set up replication with your SkySQL instance can be found [here](../Data%20loading%2C%20Migration/Replicating%20data%20from%20external%20DB/).
- Automatic Nightly Backups : Automated nightly backups include a full backup of every database in the service to ensure that your SkySQL Database service is backed up regularly. Nightly backups are running for every SkySQL database by default.
- Bring Your Own Bucket (BYOB) : You can backup or restore data to/from your own bucket in either GCP or AWS. Sample GCP and AWS scripts can be found [here](../Backup%20and%20Restore/Bring%20Your%20Own%20Bucket%20Examples/).
- Point-in-time Recovery : You can restore from a full or a logical backup and then use a binlog backup to restore to a point-in-time.
- Secure Backup/Restores : Control backup/restore privileges by granting roles to users in SkySQL.
- Other Backup API Examples : Various API scripts providing examples of listing backups, checking backup statuses, and working with backup schedules can be found [here](../Backup%20and%20Restore/Other%20backup%20API%20examples/).
Restores
Warning
Restoring from a backup will, by default, erase all data in your target DB service. If you are uncertain, it is advisable to first create a backup of the DB service before initiating the restore process. Consider restoring to a new database instance as a preferred approach. For restores other than logical dumps, the database being restored will be temporarily stopped during the restoration.
Users can instruct the restore of their SkySQL Database from their own SkySQL storage or from an external storage they own. The restore API provides options for listing, adding, and deleting a scheduled restore operation.
List Restore Schedules
SkySQL Users can fetch their already existing database restore schedules using the backup API. Check the provided API examples for details.
Restore List Examples
Create a Restore
SkySQL Users can restore their databases using their own SkySQL managed backup storage or using an external storage they own. Check the provided service API examples for details.
Database Restore Examples
Delete Restore Schedule
SkySQL Users can delete their already defined database restore schedules with the provided service API.
Delete Restore Examples
GTID Considerations for Logical Dumps
When restoring from a logical dump in MariaDB:
- The GTID state is not preserved by default in logical dumps
- If you're using replication, you'll need to:
- Either reset the GTID state after restore
- Or use
mysqldump --dump-slave
to include GTID information in the backup
- Consider using physical backups (mariabackup) instead, as they preserve GTID state
Limitations
- Currently, SkySQL services deployed in Azure can only be backed up and restored using SkySQL Snapshots.
- SkySQL Managed backups can only be restored within the same cloud provider. If you need to restore to a SkySQL service hosted on a different cloud provider, you must export your backup to S3 or GCS storage and follow the steps described here.